<template>
  <el-config-provider :locale="locale" :size="assemblySize" :button="buttonConfig">
    <router-view></router-view>
  </el-config-provider>
</template>

<script setup lang="ts">
import { onMounted, reactive, computed } from "vue"
import { useI18n } from "vue-i18n"
import { getBrowserLang } from "@/utils"
import { useTheme } from "@/hooks/useTheme"
import { ElConfigProvider } from "element-plus"
import { LanguageType } from "./stores/interface"
import { useGlobalStore } from "@/stores/modules/global"
import en from "element-plus/es/locale/lang/en"
import zhCn from "element-plus/es/locale/lang/zh-cn"

const globalStore = useGlobalStore()

// 初始化 主题
const { initTheme } = useTheme()
initTheme()

// 初始化 语言
const i18n = useI18n()
onMounted(() => {
  const language = globalStore.language ?? getBrowserLang()
  i18n.locale.value = language
  globalStore.setGlobalState("language", language as LanguageType)
})

// element 语言
const locale = computed(() => {
  if (globalStore.language == "zh") return zhCn
  if (globalStore.language == "en") return en
  return getBrowserLang() == "zh" ? zhCn : en
})

// element 尺寸
const assemblySize = computed(() => globalStore.assemblySize)

// element 按钮配置
const buttonConfig = reactive({ autoInsertSpace: false })
</script>
